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SYSTEM FOR TESTING DEVICES AND METHOD THEREOF 

FIELD OF THE DISCLOSURE 

The present invention relates generally to the testing of devices and more particularly to test 
fixtures. 

BACKGROUND 

Newly manufactured products are tested to ensure they conform to operating specification 
requirements. Depending on the type of product, various testing techniques are used. For example, 
for hardware devices, such as processing devices, test fixtures are created to provide an input 
stimulus and monitor outputs of the device for proper responses. If, for each of the input stimulus, 
the output is as anticipated, the printed circuit board passes the test. 

Some processing devices include built-in self-test (BIST) capabilities. Some processing 
devices include scan-testing as part of their BIST capabilities. A processing device may be broken 
down into a set of logic gates. The logic gates are linked together to form a serried of linked logic 
gates known as a scan chain. A set of input values, known as a scan pattern, is loaded into the inputs 
of the logic gates of the scan chain. Once all the logic gates of the scan chains have been assigned 
an input value, the input values are latched into associated logic gates. The outputs of the logic gates 
may then be shifted out from the scan chain. The outputs from the scan test are compared to known 
outputs. If the tested outputs match the known outputs, the device is considered good. If the tested 
outputs are not equivalent to the known outputs, the device has failed. By analyzing which outputs 
from the scan chain were incorrect, specific faulty portions of the processing device may be 
identified. While scan-testing allows specific faulty portions of a processing device to be identified, 
scan-testing does not test all the capabilities of a processing device. 

To adequately test a particular processing device, the processing device must be tested 
against operating conditions in which the processing device will be used, such as through at-speed 
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tests. General-purpose, automated test equipment is generally used to test processing devices, such 
as microprocessors, microcontrollers, video graphic processors, etc. A simulated design verification 
suite, based on a hardware description language, of an integrated circuit being tested is used to create 
a virtual environment to test the integrated circuit. While the automated test equipment provides 

5 flexibility such that various processing devices may be tested, it is generally a costly piece of 
equipment (e.g., approximately $2 Million Dollars U.S.). The development of the customized test 
program is somewhat time consuming, which adds additional costs to the overall automated testing 
process. Furthermore, while capabilities of the processing device may be verified while testing the 
processing device in a particular environment, specific faulty portions of the processing device may 

10 not be identified. From the above discussion it is apparent that an improved system for testing a 

% processing device is needed. 

Hi BRIEF DESCRIPTION OF THE DRAWINGS 

Specific embodiments of the present invention are shown and described in the drawings 
presented herein. Various objects, advantages, features and characteristics of the present invention, 
l|S;J as well as methods, operations and functions of related elements of structure, and the combination of 
£I S parts and economies of manufacture, will become apparent upon consideration of the following 
^ description and claims with reference to the accompanying drawings, all of which form a part of this 
specification, and wherein: 

FIG. 1 is a block diagram illustrating a system for scan-testing a processing device, according 
20 to one embodiment of the present invention; 

FIG. 2 is a flow diagram illustrating a method of scan-testing a processing device, according 
to one embodiment of the present invention; 

FIG. 3 is a block diagram illustrating a system for providing both scan-testing and at-speed 
testing of a processing device, according to one embodiment of the present invention; 
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FIG. 4 is a flow diagram illustrating a method of handling both scan and at-speed tests of a 
processing device, according to one embodiment of the present invention. 

DETAILED DESCRIPTION OF THE FIGURES 

At least one embodiment of the present invention provides for a method of production testing 
a video device. The method includes mounting a device on a test fixture. The test fixture is 
connected to a general-purpose computer. The general-purpose computer is used to provide 
commands to the test fixture for running a scan test. The method includes testing the device using 
scan techniques. The testing includes serially providing a first test vector to the device and clocking 
the device to assert the first test vector within the device. The first test vector may include a scan 
pattern clocked into at least a first scan chain of the device. The testing also includes serially 
providing a second test vector to the device. The testing further includes a step of receiving results 
from the first test vector concurrently with the step of providing the second test vector. The results 
are then compared to expected results to determine if the device is operating properly. In one 
embodiment, the method also includes providing at-speed testing of the device. 

Referring now to FIG. 1, a block diagram illustrating a system for scan-testing a video 
processing device, test device 130, is shown, according to one embodiment of the present invention. 
A general-purpose computer, host system 110, is used to generate and load a scan-test pattern (not 
shown) into test device 130 for performing a scan-test. Test device 130 is broken down into several 
scan-chains for testing. A user interface 129 may be provided to allow a user to select a particular 
scan chain to be tested in test device 130. A user may also monitor any output results generated 
from test device 130, through user interface 129. 

Host system 110 includes a general-purpose information handling system. A processor 118 
provides functionality to handle general processing for host system 110. Processor 118 runs 
applications stored in memory 116. In one embodiment, processor 118 is used to run a scan-test 
application (not shown) stored in memory 116. The scan-test application is used to generate control 
signals for running a scan-test within a processing device, such as test device 130. The control 
signals include signals to initiate a built in self test (BIST) within test device 130. The scan-test 
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application provides a scan pattern to load into a selected scan chain of test device 130. A Joint Test 
Action Group (JTAG) port 1 14 provides the control signals, a clock signal and serialized data, to test 
fixture 120, through a JTAG cable 126. In one embodiment, test fixture 120 includes a JTAG 
interface 122 to interface with JTAG port 114, through JTAG cable 126. It should be appreciated 
5 that other forms of interfaces may be used in place of JTAG port 1 14 without departing from the 
scope of the present invention. For example, a serial or parallel port may be used to interface 
between host system 110 and test fixture 120. For example, in an alternate embodiment, the control 
signals are provided through a parallel port; accordingly, a serial shifter may be used to convert 
parallel control data into serialized control data. 

ttp A control module 125 is used to initiate a scan-test within test device 130. Logic gates (not 

, 'S shown) in test device 130 are organized together as scan chains, to allow them to be linked for 
testing. In one embodiment, the logic gates are organized into subsets of scan chains. The scan 
f !J pattern generated by the test application in memory 1 16 is loaded into a particular scan chain to test 
y the logic gates of the particular scan chain. In one embodiment, a scan chain to be tested is selected 
IS through a scan chain selector 126. In one embodiment, the scan chain to be tested is manually wired 
y K to control module 125 by a user. A user interface 129 may be provided to allow the user to select a 
||J scan chain of scan chain selector 126. Alternatively, a user on host system 110 may select scan 
Q chains to be tested. In another embodiment, the test application generates control signals to indicate 
to scan chain selector 126 which of the available scan chains of test device 130 to test. Control 
20 signals for selecting scan chains may be sent by host system 110 through JTAG port 126. 
Alternatively, host system 110 may provide control signals for selecting scan chains through an 
input/output adapter 113. Input/output adapter 110 includes an interface for communicating with 
host system 110, such as a serial or parallel port interface. 

Scan chain selector 126 provides the scan pattern to a selected scan chain of test device 130, 
25 through test socket 1 28 . A clock signal (not shown) may also be provided to test device 1 30 to allow 
the scan pattern to be clocked into the gates of the selected scan chain. In one embodiment, once the 
scan pattern has been loaded into all the logic gates of the selected scan-chain, the logic gates of the 
scan chain are clocked to allow test results to be generated. In one embodiment, the output values 
from each of the logic gates of the scan chain are shifted to generate a stream of test results. It 
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should be noted the process of selecting a scan chain and loading a scan pattern into the scan chain 
may be repeated for a plurality of scan chains to be tested. Once the plurality of scan chains have 
scan patterns loaded into them, all of the selected scan chains may be clocked in unison to generate 
multiple sets of output results. Each of the results may then be compared to expected results known 
5 for each particular scan chain used. 

In one embodiment, the test results are read by control module 125, through test socket 128. 
The test results may be provided back to host system 1 10 for analyses by the test application. 
Alternatively, the test results may be provided to a user for analyses, such as through user interface 
129. The user may use a signal probe to analyze the generated test results. Alternatively, the test 
i£f! results may be read by host system 110 through input/output adapter 113. The test results are 
, J compared to a set of known test results associated with the selected scan chain and the scan pattern. 
% If the test results are equivalent to the known results, the logic gates of the scan chain have passed 
ft! the scan-test. If the test results are different from the known results, the logic gates have failed the 
y, scan-test. The faulty values of the test results may be analyzed to determine which of the logic gates 
15 in the scan chain are faulty. For example, a third logic gate of the scan chain may be associated with 
\A a third value of the test results. Accordingly, if the third value of test results if wrong, the third logic 
kji gate of the scan chain may be considered faulty. It should be noted that while control 125 and scan 
O chain selector 126 have been shown as part of test fixture 120, in an alternate embodiment, control 
125 and scan chain selector 126 form internal components of test device 130. Accordingly, 
20 commands provided to test device 130, through test fixture 120, would be used to send control 
commands to control module 125 and select scan chains through scan chain selector 126 within test 
device 130. 

Referring now to FIG. 2, a flow diagram illustrating a method of scan-testing a processing 
device is shown, according to one embodiment of the present invention. A device with a built in 
25 self-test may include dual modes of operation. In a first mode of operation, the device is allowed to 
operate in a normal mode, processing data according to its design. In a second mode of operation, 
the device is in a scan-test mode. Logic gates within the device may be linked together as a single 
chain, a scan chain. Values may be loaded into the individual logic gates of a scan chain. The 
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output of the gates may then be read to determine if any of the logic gates of the scan chain are 
faulty. 

In step 210, a particular scan chain to test is identified. While a single scan chain may be 
constructed to test all the logic gates of the device, the time to load values into the entire scan chain 
is longer than using smaller subsets of scan chains. In one embodiment, a test pattern may be loaded 
into all the scan chains for concurrent testing. Alternatively, to test only a particular portion of the 
device, only a scan chain associated with the particular portion of the device may need to be tested. 
The desired scan chain to be tested is selected from a plurality of scan chains associated with the 
device to be tested. 

In step 220, the desired scan chain is selected within a test fixture. In one embodiment, 
access to different scan chains is provided through settings within the test fixture, such as test fixture 
120 (FIG. 1), used to interface with the device. The access to the desired scan chain may be 
provided by manually connecting wires to a circuit network associated with the desired scan chain. 
In one embodiment, a multiplexer is provided to select the desired scan chain. A test application 
may also be used to provide signals to the test fixture to select the desired scan chain. 

In step 230, a scan pattern is selected. The scan pattern represents the values that will be 
loaded into the logic gates of the scan chain. It should be noted that to adequately test a particular 
scan chain, several different scan patterns may be needed. In one embodiment, the scan pattern is 
selected through a test application within a host system connected to the test fixture. The test 
application provides the scan pattern to the test fixture. Different scan patterns may be preloaded in 
the test application, allowing a user to select a scan pattern to use. Alternatively, the user may 
provide a test pattern to be loaded. In one embodiment, the test pattern is repeated throughout the 
scan chain, allowing all the logic gates of the scan chain to be loaded with a value of the scan 
pattern. 

In step 240, the device to be tested is placed in a scan-test mode. Control signals are sent to 
the device being tested to engage the built in self test and prepare the device to receive the scan 
pattern. In one embodiment, the control signals are sent to the device via a JTAG port. The control 
signals include commands for setting the device being tested in a debug mode. The device may 
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support a variety of test modes, which are engaged through commands received by the device 
through a JTAG port. 

In step 245, the selected scan pattern is shifted into the desired scan chain. A clock signal is 
provided to the device to allow the scan pattern values to be provided to the inputs of the scan chain 
5 logic gates. Once the inputs of the logic gates all have a value of the scan pattern, a clock pulse is 
provided to latch the input values into the logic gates. In step 250, once all the logic gates have 
values of the scan pattern, the test fixture shifts out the outputs of the scan chain logic gates. It 
should be noted that multiple scan chains may be selected and provided scan patterns. All the scan 
chains may then be tested by shifting out the values of the different scan chains. 

iM In step 260, the data shifted out of the scan chain is compared to a set of expected results. It 

Hp should be noted that the set of expected results may be unique to the scan pattern used and the scan 
3j chain being tested. If the scan chain tested is changed or the scan pattern is changed, the expected 
'f* results may also change. Accordingly, expected results should be known for the particular scan 
chain being tested with the particular scan pattern used. In step 270, if the shifted output data is 

lBs equivalent to the expected results, the scan chain has passed the test. As previously discussed, 
1 v further testing may also be performed using a different scan pattern to ensure the scan chain is truly 
Q working. In step 280, if the shifted output results do not match the expected results, the scan chain 
: has failed the scan-test. In step 285, the particular portion of the scan chain that has failed is 
identified. The shifted output data values that did not match the expected results may be examined 

20 to determine which logic gates of the scan chain failed the scan-test. 

Referring now to FIG. 3, a block diagram illustrating a system for providing both scan- 
testing and at-speed testing of a processing device is shown, according to one embodiment of the 
present invention. A host system 310 generates control signals for testing a device, such as test 
device 330. The host system 310 generates commands for two types of tests, an at-speed test and a 
25 scan-test. The at-speed tests are run to test the operations of test device 330 at a speed in which test 
device 330 is expected to operate at. The host system 310 also may switch the test device 330 to a 
scan-test in which particular scan chains of test device 330 are tested by shifting in scan patterns. 
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Host system 310 includes a processor for running applications stored in memory 3 16. In one 
embodiment, memory 316 includes a test application (not shown). The test application is capable of 
running commands to initiate either an at-speed test or a scan-test of test device 330, through test 
fixture 320. Commands generated through the test application are provided to a host bus port 312, 
through system bus 112. Test fixture 320 includes a host bus interface 322 for interfacing with host 
bus port 312 of host system 310. In one embodiment host bus port 312 is an accelerated graphics 
port (AGP). Host bus port 312 may also include a peripheral component interconnect (PCI) bus port 
or a JTAG port. 

In one embodiment, commands provided through the host bus interface unit 322 are used to 
select a test mode within test fixture 320, through test mode selector 323. Test mode selector 323 
may then route the test signals through one of two paths, an at-speed test path 340 and a scan-test 
path 350. Test commands sent along the at-speed path 340 are sent to test socket 328 to allow the 
test device 330 to process the test commands under a speed and operating conditions in which the 
test device 330 is expected to run. In one embodiment, the test device 330 may operate in either a 
scan test mode or an at-speed test mode, exclusively. A save and restore procedure may be 
employed to ensure the test device 330 is put in a proper operative mode without powering down the 
test device 330. A power supply control 340 may include circuitry to control power-up or power- 
down sequences used during testing of test device 330. 

In one embodiment, commands sent to control module 325 are used to select a particular scan 
chain of test device 330 to be tested. In one embodiment, scan chain selector 326 is a demultiplexer 
which provides data provided by control 325 to a particular circuit network associated with 
particular scan chains. Scan chain selector 326 may also include a switch to allow a particular scan 
chain network to be selected. Scan chain selector 326 provides scan patterns provided by control 
module 325 to the test device 330, through test socket 328. 

Results from the tests, either at-speed tests or scan-tests, may be sent back to host system 
320, through host bus interface 322, for analysis. In one embodiment, the test results are analyzed 
by the test application in memory 316. The test application may be used to compare test results 
against known results. At-speed tests may be analyzed to determine if any anomalies in the 
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processing performed by test device 330 are present. In one embodiment, if any anomalies are 
detected during at-speed tests, the host system 3 10 switches to a scan-test mode. The test device 330 
is halted and test commands are processed through the scan-test path 350. Test results may be 
compared against expected scan-test results to determine if any of the logic gates of test device 330 
5 are faulty. Alternatively, a scan test may be run to and the test device 330 may be halted to switch to 
at-speed tests. Portions of test device 330 which are faulty or degrading performance may be 
identified, as described further in reference to FIG. 4. 

Referring now to FIG. 4, a flow diagram illustrating a method of handling both scan and at- 
speed tests of a processing device is shown, according to one embodiment of the present invention, 
lj A device is tested using a scan test. If the device passes the scan test, the device is set to an at-speed 
•| test mode to provide more robust testing. An at-speed test may be performed to identify the source 
J: of the problem with the device. 

j* In step 410, processing in the device to be tested is halted to allow a scan test to be engaged. 

:^ In step 420, a scan test mode of the device is engaged. In one embodiment, the device is capable of 
m being placed in a scan test mode using commands received by the device through a JTAG port. For 

m example, commands may be sent to the device to engage a BIST associated with the device. A 

g particular scan chain may be selected for testing. In one embodiment, the device includes a plurality 
of scan chains. To test particular portions of the device, particular scan chains, which may include 
specific components associated with particular processing functions of the device, are selected for 
20 testing. A scan pattern for testing the selected scan chains may also be selected. In step 430, the 
scan-test is run on the device. The selected scan pattern is loaded into the selected scan chains. 
Once all the components, or logic gates, associated with the selected scan chains have values, the 
components are clocked to determine the results of the scan-test. The outputs of the scan-test are 
read from the device being tested. 
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In step 440, the test results are compared to a set of expected results. For every scan chain 
tested with a particular scan pattern, a unique set of test results is expected. If the test results match 
the expected results, the device is considered to pass the scan test. In one embodiment, if the device 
passes the scan test, the device is set to real-time operation for further testing, as in step 460. 
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Alternatively, the device may be placed in a "good part" bin which may indicated the scan test has 
passed, allowing the device to be picked up at a later time to proceed with at-speed testing. In step 
450, if the test results do not equal the expected results, the device has failed testing and is 
considered faulty. The device may be placed in a "bad part" bin, indicated the device has failed 
testing. In one embodiment, the particular scan chain that failed the scan-test is analyzed to 
determine which portion of the device being tested is faulty, allowing an assessment of fault to be 
determined. 

In step 460, the device is set to real time operation to prepare for at-speed testing. The device 
may be provided connection to other system devices and resources with which the device will 
operate in. The device is allowed to run with a clock representing a speed in which the device is 
expected to operate within. In step 470, at-speed test commands are provided to the device being 
tested. The at-speed test commands include processing commands which the device to be tested is 
expected to adequately process at a real-time speed. In one embodiment, the device to be tested 
includes a graphics processor. Accordingly, the at-speed test commands may include three- 
dimensional (3-D) graphics processing commands. 

In step 480, it is determined if any artifacts are present. Processing results from the test 
commands being run on the device are compared to expected results. In one embodiment, a 
resulting frame-rate is compared to a target frame rate to determine if the device is processing as 
expected. In step 490, if no artifacts are detected, the device is considered to be operating correctly 
and is passed. Alternatively, more test commands may be sent to the device is provide more 
thorough testing. Devices that have passed testing may be placed in a "good part" bin to indicate the 
device has passed testing. If artifacts are detected in step 480, the device may be considered faulty 
and fail the testing, as in step 450. 

The systems described herein may be part of an information handling system. The term 
"information handling system" refers to any system that is capable of processing information or 
transferring information from one source to another. An information handling system may be a 
single device, such as a computer, a personal digital assistant (PDA), a hand held computing device, 
a cable set-top box, an Internet capable device, such as a cellular phone, and the like. Alternatively, 
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an information handling system may refer to a collection of such devices. While the present 
disclosure has been described in reference to testing a video device, it should be appreciated that the 
present invention may be used for testing other types of devices. For example, the present invention 
may be used for production testing audio devices, signal processing devices, video gaming devices, 
computing processors and the like. It should be appreciated that the system described herein has the 
advantage of providing an improved production testing of a device. 

In the preceding detailed description of the embodiments, reference has been made to the 
accompanying drawings which form a part thereof, and in which is shown by way of illustration 
specific embodiments in which the invention may be practiced. These embodiments are described in 
sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood 
that other embodiments may be utilized and that logical, mechanical and electrical changes may be 
made without departing from the spirit or scope of the invention. To avoid detail not necessary to 
enable those skilled in the art to practice the invention, the description may omit certain information 
known to those skilled in the art. Furthermore, many other varied embodiments that incorporate the 
teachings of the invention may be easily constructed by those skilled in the art. Accordingly, the 
present invention is not intended to be limited to the specific form set forth herein, but on the 
contrary, it is intended to cover such alternatives, modifications, and equivalents, as can be 
reasonably included within the spirit and scope of the invention. The preceding detailed description 
is, therefore, not to be taken in a limiting sense, and the scope of the present invention is defined 
only by the appended claims. 
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